

Digitální elektronika 1

Projekt VHDL:

Running text 7-seg display

## Autoři:

David Strouhal Martin Zárecký Michal Marek



- Cíle projektu
- Popis hardwaru
- Popis projektu a simulací modelů VHDL
- Popis modulu TOP a jeho simulace
- Reference



- Posouvání textu po 7-segmentových displejích
- Resetu do výchozí pozice
- Zvolit si z možností předdefinovaných textů



Popis hardwaru

 Využíváme desku Nexys A7 s FPGA Artix 7





## • Komponenty projektu

| Zdroje (sources)            | Simulace (sim)                 |
|-----------------------------|--------------------------------|
| alphabet_7seg.vhd           | tb_alphabet_7seg.vhd           |
| alphabet_to_code.vhd        | tb_alphabet_to_code            |
| driver_7seg_8characters.vhd | tb_driver_7seg_8characters.vhd |
| bus_multiplexer_pkg.vhd     | (package)                      |
| clock_enable.vhd            | tb_clock_enable                |
| cnt_up_down.vhd             | tb_cnt_up_down                 |
| move_text.vhd               | tb_move_text                   |
| newtop.vhd                  | tb_new_top                     |
| switch_to_message.vhd       | tb_switch_to_message           |

```
generic map(
                                                        default length => 32
entity newtop is
   Port ( CLK100MHZ : in STD LOGIC;
         CA : out STD_LOGIC;
                                                  port map(
         CB : out STD LOGIC;
                                                        sw state i => SW,
         CC : out STD LOGIC;
         CD : out STD_LOGIC;
                                                        text o => text text,
         CE : out STD LOGIC;
         CF : out STD LOGIC;
                                                        text length move : entity work.move_text
         CG : out STD LOGIC;
                                                                               generic map(
         AN : out std logic vector (7 downto 0);
                                                                                   default_speed => 50000000
         BTNC : in std logic;
         SW : in STD_LOGIC_vector(15 downto 0);
                                                                               port map(
         BTND : in STD logic
                                                                                   clk
                                                                                          => CLK100MHZ,
end newtop;
                                                                                   reset
                                                                                         => BTND,
                                                                                   code i => code,
switch : entity work.switch to message
                                                                                     code i => ("000001", "000010", "000011", "000100", "000101", "000110", "000111", "001000", "0000
                                                                                   code length i => length,
    generic map(
                                                                                   data0 o => data0,
         default length => 32
                                                                                   data1 o => data1,
                                                                                   data2_o => data2,
    port map(
                                                                                   data3 o => data3,
         sw state i => SW,
                                                                                   data4 o => data4,
                                                                                   data5 o => data5,
         text o => text text,
                                                                                   data6 o => data6,
         text length => length
                                                                                   data7 o => data7
    );
                                                                               );
```

switch : entity work.switch to message









## Reference

- 1.Tabulka znaků na 7-seg displeji
- •https://codegolf.stackexchange.com/questions/173837/longest-sevensegment-word
- 2. Nexs A7 Refernce Manual
- •https://digilent.com/reference/programmable-logic/nexys-a7/reference-manual
- 3. Segmenty 7-seg displeje
- •https://lastminuteengineers.b-cdn.net/wpcontent/uploads/arduino/Common-Cathode-7-Segment-Display-Internal-Working.gif
- 4. Popis 7-seg displeje
- •https://lastminuteengineers.com/seven-segment-arduino-tutorial/
- 5.Nejdelší 7-seg slovo
- •https://codegolf.stackexchange.com/questions/173837/longest-sevensegment-word





